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CLAIMS 

What is claimed is: 

11. A method for performing memory disambiguation in a compiler, comprising: 

2 determining memory objects corresponding to memory references in one or 

3 more source files being compiled; 

4 creating a memory disambiguation token for each memory reference, each 

5 memory disambiguation token identifying information particular to the memory 

6 reference it Is associated with so as to preserve high-level and intermediate-level 
':t semantic information 

P creating a symbolic memory reference representation associated with each 

memory disambiguation token, including information on whether the memory reference 
I® is indirect or direct and access to symbol table information for a pointer to the memory 
\l object for indirect references or the memory object for direct references; and 

10. determining if potentially dependent memory references are dependent or 

liJ 

13 independent based on information contained in the disambiguation tokens for those 

n 

13- memory references and their associated symbolic memory reference representations. 

1 2. The method of claim 1 , further comprising determining if memory references are 

2 redundant based on information contained in the disambiguation tokens for those 

3 memory references and their associated symbolic memory reference representations. 

1 3. The method of claim 1 , further comprising determining a relative difference in 

2 starting addresses for two memory references that are determined to be Independent or 

3 dependent. 
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1 4. The method of claim 1 , wherein the disambiguation token comprises a data 

2 structure including a plurality of links to data objects in which disambiguation 

3 information are stored 

1 5. The method of claim 4, wherein the data structure is embedded in memory 

2 reference operators of an intermediate language produced during the compilation of 

3 said one or more source files. 

1 6. The method of claim 1 , wherein the disambiguation token associated with the 

2 memory object includes a key that is used to access a table of data dependence 
J^.j information. 

^ 7. The method of claim 1 , wherein the disambiguation token contains a link to 

address base and offset information for the memory reference that is used for low-level 

rij 

h3 disambiguation, 

a 
ry 

d 8. The method of claim 1 , further comprising: 

B 

i2 substituting a direct memory reference for an indirect memory reference; and 

3 updating the disambiguation token corresponding to the memory reference to 

4 indicate the memory reference is now a direct memory reference. 

1 9. The method of claim 1 , further comprising using information identified by 

2 disambiguation tokens to determine sets of local memory objects that are not 

3 referenced after they are modified. 

1 1 0. The method of claim 1 , further comprising determining if two memory references 

2 access overlapping memory locations based on information contained in the 

23 



Attorney Docket: 0412390. PI 0809 




3 disambiguation tokens for those memory references and their associated symbolic 

4 memory reference representations. 

1 11. The method of claim 10, further comprising determining particularities of an 

2 overlap between two overlapping memory references. 

1 1 2. The method of claim 1 , further comprising: 

2 determining the functions executed corresponding to function calls in the one or 

3 more source files being compiled; 

4 creating a disambiguation token for each function call, each disambiguation 

J token identifying information particular to the function call It is associated with so as to 

r\% 

fg preserve high-level and intermediate level semantic information; 

^7 creating a symbolic function call representation associated with each 

: 

jS disambiguation token, including information on whether the function call is indirect or 

^3 direct and access to symbol table information for the pointer or function respectively; 

id and 

rij 

tj determining if potentially dependent calls and memory references are dependent 

11 or independent for the function calls based on information contained in the 

13 disambiguation tokens for the calls and memory references, their associated symbolic 

14 representation, an analysis of each function to determine the set of memory locations 

15 modified or referenced by the function. 

1 13. The method of claim 1 , wherein the disambiguation token contains a link to type 

2 information associated with the memory reference. 
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1 14. The method of claim 1 , wherein the disambiguation token for an indirect memory 

2 reference contains a link to a set of memory objects accessible via the pointer as 

3 determined by points-to analysis. 

1 15. The method of claim 1 , further comprising using the disambiguation token and 

2 the symbolic memory reference representation as an interface or means of 

3 communication between various software components of a disambiguator that performs 

4 memory disambiguation functions and clients of the disambiguator. 



1 16. A system comprising: 

J2 a memory in which a plurality of machine instructions comprising a compiler and 

p| programming code corresponding to one or more source files are stored; and 

H a processor coupled to the memory, executing the machine instructions to 
perform the functions of: 

ru 

'6 determining memory objects corresponding to memory references in said 

ill 

W one or more source files; 

fi j 

^8 creating a memory disambiguation token for each memory reference, 

\9 each memory disambiguation token identifying information particular to the 

10 memory reference it is associated with so as to preserve high-level and 

1 1 intermediate-level semantic information 

12 creating a symbolic memory reference representation associated with 

13 each memory disambiguation token, including information on whether the 

14 memory reference is indirect or direct and access to symbol table information for 

15 a pointer to the memory object for indirect references or the memory object for 

16 direct references; and 

17 determining if potentially dependent memory references are dependent or 

18 independent based on information contained in the disambiguation tokens for 
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19 those memory references and their associated symbolic memory reference 

20 representations. 

1 1 7. The system of claim 1 6, wherein execution of the machine instructions by the 

2 processor further performs the function of determining if memory references are 

3 redundant based on information contained in the disambiguation tokens for those 

4 memory references and their associated symbolic memory reference representations. 

1 1 8. The system of claim 1 6, wherein execution of the machine instructions by the 

2 processor further performs the function of determining relative positions of starting 

J| addresses for memory references that are independent or dependent. 

m 



iX 19. The system of claim 16, wherein execution of the machine instructions by the 

5 processor further performs the functions of: 

6 substituting a direct memory reference for an indirect memory reference; and 

lij 

14 updating the disambiguation token corresponding to the memory reference to 

rli 

indicate the memory reference Is now a direct memory reference. 

D 

1 20. The system of claim 16, wherein execution of the machine Instructions by the 

2 processor further performs the function of using information Identified by 

3 disambiguation tokens to determine sets of local memory objects that are not 

4 referenced after they are modified. 

1 21 . The system of claim 1 6, wherein execution of the machine instructions by the 

2 processor further performs the function of determining if two memory references access 

3 overlapping memory locations based on information contained in the disambiguation 
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4 tokens for those memory references and their associated symbolic memory reference 

5 representations. 

1 22. The system of claim 1 6, wherein execution of the machine instructions by the 

2 processor further performs the functions of: 

3 determining the functions executed corresponding to function calls in the one or 

4 more source files being compiled; 

5 creating a disambiguation token for each function call, each disambiguation 

6 token identifying information particular to the function call it is associated with so as to 

7 preserve high-level and intermediate level semantic information; 

J"! creating a symbolic function call representation associated with each 

P§ disambiguation token, including information on whether the function call is indirect or 

ifl direct and access to symbol table information for the pointer or function respectively; 

ti and 

rij 

t2 determining if potentially dependent calls and memory references are dependent 



13 or independent for the function calls based on information contained in the 

rij 

14 disambiguation tokens for the calls and memory references, their associated symbolic 
%S representation, an analysis of each function to determine the set of memory locations 
16 modified or referenced by the function. 

1 23. An article of manufacture on which a plurality of machine instructions comprising 

2 a compiler are stored that upon execution of the machine instructions by a processor 

3 causes the functions to be performed, including: 

4 determining memory objects corresponding to memory references in said one or 

5 more source files; 

6 creating a memory disambiguation token for each memory reference, each 

7 memory disambiguation token identifying information particular to the memory 
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8 reference it is associated with so as to preserve high-level and intermediate-level 

9 semantic information 

10 creating a symbolic memory reference representation associated with each 

1 1 memory disambiguation token, including information on whether the memory reference 

12 is indirect or direct and access to symbol table information for a pointer to the memory 

13 object for indirect references or the memory object for direct references; and 

14 determining if potentially dependent memory references are dependent or 

15 independent based on information contained in the disambiguation tokens for those 

16 memory references and their associated symbolic memory reference representations. 

II 24. The article of manufacture of claim 23, wherein execution of the machine 

li instructions further performs the function of determining if memory references are 

I . ! 

g redundant based on information contained in the disambiguation tokens for those 
memory references and their associated symbolic memory reference representations. 

5 

i'l 25. The article of manufacture of claim 23, wherein execution of the machine 

^2 instructions further performs the function of determining relative positions of starting 

fi 

=3 addresses for memory references that are independent or dependent. 

1 26. The article of manufacture of claim 23, wherein execution of the machine 

2 instructions further performs the functions of: 

3 substituting a direct memory reference for an indirect memory reference; and 

4 updating the disambiguation token corresponding to the memory reference to 

5 indicate the memory reference is now a direct memory reference. 

1 27. The article of manufacture of claim 23, wherein execution of the machine 

2 instructions further performs the function of using information identified by 
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3 disambiguation tokens to determine sets of local memory objects that are not 

4 referenced after they are modified. 

1 28. The article of manufacture of claim 23, wherein execution of the machine 

2 instructions further performs the function of determining if two memory references 

3 access overlapping memory locations based on information contained in the 

4 disambiguation tokens for those memory references and their associated symbolic 

5 memory reference representations. 

1 29. The article of manufacture of claim 23, wherein execution of the machine 

[i instructions further performs the functions of: 

p3 determining the functions executed corresponding to function calls in the one or 

i ( I 

J4 more source files being compiled; 

r'- 

^1 creating a disambiguation token for each function call, each disambiguation 

^6 token identifying information particular to the function call it is associated with so as to 

17 preserve high-level and intermediate level semantic information; 

i iJ 

'^8 creating a symbolic function call representation associated with each 

5iix 

1=9 disambiguation token, including information on whether the function call is indirect or 

10 direct and access to symbol table information for the pointer or function respectively; 

11 and 

12 determining if potentially dependent calls and memory references are dependent or 

13 independent for the function calls based on information contained in the disambiguation 

14 tokens for the calls and memory references, their associated symbolic representation, 

15 an analysis of each function to determine the set of memory locations modified or 

16 referenced by the function. 
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1 30. The article of manufacture of claim 23, wherein execution of the machine 

2 instructions further performs the functions of using the disambiguation token and the 

3 symbolic memory reference representation as an interface or means of communication 

4 between various software components of a disambiguator that performs memory 

5 disambiguation functions and clients of the disambiguator. 
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